package com.sky.mapper;

import com.sky.entity.AddressBook;
import org.apache.ibatis.annotations.*;

import java.util.List;

@Mapper
public interface AddressBookMapper {
    // 根据当前用户id查询当前用户的所有地址
    @Select("select * from address_book where user_id = #{userId}")
    List<AddressBook> getAllAddressBook(AddressBook addressBook);

    // 更新地址
    void updateAddressBook(AddressBook addressBook);

    // 新增地址
    @Insert("insert into address_book(user_id, consignee,sex, phone,province_code,province_name,city_code,city_name,district_code,district_name,detail,label,is_default) " +
            "values(#{userId},#{consignee},#{sex},#{phone},#{provinceCode},#{provinceName},#{cityCode},#{cityName},#{districtCode},#{districtName},#{detail},#{label},#{isDefault})")
    void insertAddressBook(AddressBook addressBook);

    // 根据地址id查询地址
    @Select("select * from address_book where id = #{id}")
    AddressBook getAddressBookById(Long id);

    // 根据地址id删除地址
    @Delete("delete from address_book where id = #{id}")
    void deleteAddressBookById(Long id);

    // 将userID下的地址全部变为默认地址
    @Update("update address_book set is_default = #{isDefault} where user_id = #{userId}")
    void updateDefault(AddressBook addressBook);

    // 查询默认地址
    @Select("select * from address_book where is_default = 1 and user_id = #{userId}")
    List<AddressBook> getDefaultAddress(AddressBook addressBook);
}
